<template>
	<view>
		<!-- 地址 -->
		<navigator url="/pages/address/address?source=1" class="address-section">
			<view class="order-content">
				<text class="yticon icon-shouhuodizhi"></text>
				<view class="cen">
					<view class="top">
						<text class="name" v-model="addressData.name">{{addressData.name}}</text>
						<text class="mobile" v-model="addressData.mobile">{{addressData.mobile}}</text>
					</view>
					<text class="address" v-model="addressData.address">{{addressData.address}} {{addressData.area}}</text>
				</view>
				<text class="yticon icon-you"></text>
			</view>
			<image class="a-bg" src=""></image>
		</navigator>

		<view class="goods-section">
			<view class="g-header b-b">
			</view>
			<!-- 商品列表 -->
			<view class="g-item"  v-for="(item,index) in selectSp" :key="index">
				<image  :src="img+item.THUMB"></image>
				<view class="right" >
					<text class="title clamp" >{{item.NAME}}</text>
					<text class="spec" >{{item.SHORTINFO}}</text>
					<view class="price-box">
						<view class="" v-if="item.MULTIPAY==2" >
							<text  class="price" v-if="item.OPPOINT>0">积分:{{item.OPPOINT}}</text>
							<text  class="price"  v-if="item.OPDEDU>0">抵扣券:{{item.OPDEDU}}</text>
							<text  class="price"  v-if="item.OPCOUPON>0">优惠券:{{item.OPCOUPON}}</text>
						</view>
						<view class="" v-else >
							<text  class="price"  v-if="item.MUCHSELLERPRICE>0">￥:{{item.MUCHSELLERPRICE}}</text>
							<text  class="price"  v-if="item.MPPOINT>0">+积分:{{item.MPPOINT}}</text>
							<text  class="price"  v-if="item.MPDEDU>0">+抵扣券:{{item.MPDEDU}}</text>
							<text  class="price"  v-if="item.MPCOUPON>0">+优惠券:{{item.MPCOUPON}}</text>
						</view>
						
						<text class="number">x {{num}}</text>
					</view>
				</view>
			</view>
			
		</view>

		<!-- 优惠明细 -->
		<!-- <view class="yt-list">
			<view class="yt-list-cell b-b" @click="toggleMask('show')">
				<view class="cell-icon">
					券
				</view>
				<text class="cell-tit clamp">优惠券</text>
				<text class="cell-tip active">
					选择优惠券
				</text>
				<text class="cell-more wanjia wanjia-gengduo-d"></text>
			</view>
			<view class="yt-list-cell b-b">
				<view class="cell-icon hb">
					减
				</view>
				<text class="cell-tit clamp">商家促销</text>
				<text class="cell-tip disabled">暂无可用优惠</text>
			</view>
		</view> -->
		<!-- 金额明细 -->
		<view class="yt-list"  >
			<view class="yt-list-cell b-b"  >
				<text class="cell-tit clamp"  >商品金额</text>
				<text class="cell-tip"  >￥{{amount}}</text>
			</view>
			<view class="yt-list-cell b-b" >
				<text class="cell-tit clamp">优惠金额</text>
				<text class="cell-tip red">￥{{save}}</text>
			</view>
			<view class="yt-list-cell b-b" >
				<text class="cell-tit clamp">运费</text>
				<text class="cell-tip">￥{{postAge}}</text>
			</view>
			<view class="yt-list-cell desc-cell" >
				<text class="cell-tit clamp">备注</text>
				<input class="desc" type="text" v-model="desc" placeholder="请填写备注信息" placeholder-class="placeholder" />
			</view>
		</view>
		
		<!-- 底部 -->
		<view class="footer">
			<view class="price-content">
				<text>实付款</text>
				<view class="" v-if="MULTIPAY==2" >
					<text  class="price"  v-if="amount1>0">￥:{{amount1}}</text>
					<text  class="price" v-if="OPPOINT>0">积分:{{OPPOINT}}</text>
					<text  class="price"  v-if="OPDEDU>0">抵扣券:{{OPDEDU}}</text>
					<text  class="price"  v-if="OPCOUPON>0">优惠券:{{OPCOUPON}}</text>
				</view>
				<view class="" v-else >
					<text  class="price"  v-if="amount1>0">￥:{{amount1}}</text>
					<text  class="price"  v-if="MPPOINT>0">+积分:{{MPPOINT}}</text>
					<text  class="price"  v-if="MPDEDU>0">+抵扣券:{{MPDEDU}}</text>
					<text  class="price"  v-if="MPCOUPON>0">+优惠券:{{MPCOUPON}}</text>
				</view>
			</view>
			<text class="submit" @click="submit">提交订单</text>
		</view>
		
		<!-- 优惠券面板 -->
		<view class="mask" :class="maskState===0 ? 'none' : maskState===1 ? 'show' : ''" @click="toggleMask">
			<view class="mask-content" @click.stop.prevent="stopPrevent">
				<!-- 优惠券页面，仿mt -->
				<view class="coupon-item" v-for="(item,index) in couponList" :key="index">
					<view class="con">
						<view class="left">
							<text class="title">{{item.title}}</text>
							<text class="time">有效期至2019-06-30</text>
						</view>
						<view class="right">
							<text class="price">{{item.price}}</text>
							<text>满30可用</text>
						</view>
						
						<view class="circle l"></view>
						<view class="circle r"></view>
					</view>
					<text class="tips">限新用户使用</text>
				</view>
			</view>
		</view>

	</view>
</template>

<script>
	
	export default {
		
		data() {
			return {
				img : '',
				maskState: 0, //优惠券面板显示状态
				desc: '', //备注
				payType: 1, //1微信 2支付宝
				couponList: [
					{
						title: '新用户专享优惠券',
						price: 5,
					},
					{
						title: '庆五一发一波优惠券',
						price: 10,
					},
					{
						title: '优惠券优惠券优惠券优惠券',
						price: 15,
					}
				],
				addressData: {},
				num : 0,
				save: 0,
				specList:'',
				ids : '',
				amount: 0,
				amount1: 0,
				postAge:0,
				SID: '',
				selectedSpec: [],
				price:0,
				selectSp: [],
				OPPOINT:0,
				OPDEDU:0,
				OPCOUPON:0,
				MUCHSELLERPRICE:0,
				MPPOINT:0,
				MPDEDU:0,
				MPCOUPON:0,
				MULTIPAY:0
										
			}
		},
		async onLoad(option){
			//商品数据
			// this.loadAddress();
			this.img = getApp().globalData.imageAddress;
			this.num = option.num;
			this.ids = option.id;
			this.SID = option.SID;
			this.loadData(this.ids);
			uni.startPullDownRefresh();
		},
		onPullDownRefresh() {
			console.log('refresh');
			setTimeout(function () {
				uni.stopPullDownRefresh();
			}, 1000);
		},
		onShow(){
			this.loadAddress();
		},
		methods: {
			loadAddress: function(){
				//查找默认地址
				this.$http.post("/user/defaultAddress",{
					SIGNATURE : uni.getStorageSync("SIGNATURE"),
					TOKEN: uni.getStorageSync('userInfo').TOKEN,
				}).then(e=>{
					
					if(e.data.STATE === '0' && e.statusCode === 200){
						let item = e.data.OBJECT;
						this.addressData.id = item.ID;
						this.addressData.name = item.LINKNAME;
						this.addressData.mobile = item.TEL;
						let add = item.ADDRESS.split("-");
						this.addressData.address = add[0];
						this.addressData.area = add[1];
						let a = this.addressData ;
						this.addressData = {};
						this.addressData = a;
					}else{
						if(e.data.MSG == '没有收货地址'){
							uni.showModal({
									content: '没有收货地址，请现在去设置？',
									success: (res)=>{
										if(res.confirm){
												uni.navigateTo({
													url:"/pages/address/address?source=1"
												})
											}else if(res.cancel) {
												uni.navigateBack({
													delta:2
												})
											}
										},
									})
						}else if(e.data.STATE === "906" || e.data.STATE === "907" || e.data.STATE === "903" || e.data.STATE === "904" || e.data.STATE === "905"){
							
							uni.showModal({
								content:'请重新登录',
								success: function (res) {
								        if (res.confirm) {
											// #ifdef MP-WEIXIN
								            uni.switchTab({
								            	url:"/pages/user/user"
								            })
											// #endif
											// #ifndef MP-WEIXIN
											uni.navigateTo({
												url: "/pages/public/login1"
											})
											// #endif
								        } else if (res.cancel) {
								            console.log('用户点击取消');
								        }
								    }
							})
							
						}
					}
				}).catch(err =>{
					console.log('request fail', err);
				})
			},
			async loadData(id){
				
				console.log("1111",id);
				this.$http.post("/goods/exchangeDetail",{
					SIGNATURE : uni.getStorageSync("SIGNATURE"),
					ID : id,
				}).then((res) => {
					console.log("************",res)
					this.specList = res.data.OBJECT;
					this.selectedSpec = res.data.OBJECT.LIST
					this.postAge = res.data.OBJECT.POSTAGE
					this.selectSp.splice(0,this.selectSp.length)
					this.selectedSpec.forEach(item=>{
						if(this.SID == item.SID){
							this.selectSp.push(item)
						}
					})
					this.selectSp.forEach(item=>{
						this.amount += item.MARKETPRICE*this.num
						this.save += (item.MARKETPRICE-item.MUCHSELLERPRICE)*this.num
						this.MULTIPAY = item.MULTIPAY
						if(item.MULTIPAY==2){
							if(item.OPPOINT>0){
								this.OPPOINT +=item.OPPOINT*this.num
							}
							if(item.OPDEDU>0){
								this.OPDEDU +=item.OPDEDU*this.num
							}
							if(item.OPCOUPON>0){
								this.OPCOUPON +=item.OPCOUPON*this.num
							}
						}else{
							if(item.MUCHSELLERPRICE>0){
								this.MUCHSELLERPRICE += item.MUCHSELLERPRICE*this.num
							}
							if(item.MPPOINT>0){
								this.MPPOINT += item.MPPOINT*this.num
							}
							if(item.MPDEDU>0){
								this.MPDEDU += item.MPDEDU*this.num
							}
							if(item.MPCOUPON>0){
								this.MPCOUPON += item.MPCOUPON*this.num
							}
							
						}
					})
					if(this.MUCHSELLERPRICE >  res.data.OBJECT.POSTAGEFREE){
						this.postAge = 0
					}
					this.amount1 = this.MUCHSELLERPRICE + this.postAge
					console.log("wowowowow",this.selectSp)
				}).catch((err1)=>{
					console.log('request fail', err1);
				})
				
			},
			//显示优惠券面板
			toggleMask(type){
				let timer = type === 'show' ? 10 : 300;
				let	state = type === 'show' ? 1 : 0;
				this.maskState = 2;
				setTimeout(()=>{
					this.maskState = state;
				}, timer)
			},
			numberChange(data) {
				this.number = data.number;
			},
			changePayType(type){
				this.payType = type;
			},
			submit(){
				
				console.log("13212345",this.amount)
				this.SIGNATURE = uni.getStorageSync("SIGNATURE");
				this.$http.post("/order/save",{
					SIGNATURE : this.SIGNATURE,
					TOKEN: uni.getStorageSync('userInfo').TOKEN,
					GOODSID : this.ids,
					SID: this.SID,
					AMOUNT: this.amount1,
					COUNT: this.num,	
					LINKNAME: this.addressData.name, //联系人名称
					TEL: this.addressData.mobile,	//联系人电话
					ADDRESSID: this.addressData.id,	//联系人地址id
					DESCRIBE: this.desc,	//联系人备注
					ZSACTIVITY : this.MULTIPAY,  //  2 单独优惠支付  3 组合优惠
					ZSPOINTNUM : this.MULTIPAY== 2 ? this.OPPOINT : this.MPPOINT,
					ZSDEDUNUM : this.MULTIPAY== 2 ? this.OPDEDU : this.MPDEDU,
					ZSCOUPONNUM : this.MULTIPAY== 2 ? this.OPCOUPON : this.MPCOUPON,
					ISREDEEM : 1
				}).then((res) => {
					console.log("res",res);
					if(res.data.STATE == '903'||res.data.STATE == '904'||res.data.STATE == '905'){
						uni.navigateTo({
							url:'/pages/public/login1'
						})
					}
					if (res.statusCode === 200 && res.data.STATE === '0') {  
						console.log("res1111111111111111",);
						if(res.data.OBJECT.FORWARDFLAG == 2 ){
							uni.redirectTo({
								url: '/pages/order/order?state=2'
							})
						}else{
							//跳转支付
							uni.redirectTo({
								url: '/pages/money/pay?ORDERNUM=' + res.data.OBJECT.ORDERNUM + "&AMOUNT=" + this.amount1
							})
						}
						
					}else{
						uni.showToast({title:res.data.MSG, icon:"none"});
					}
				}).catch((err)=>{
					console.log('request fail', err);
				})
				
			},
			stopPrevent(){}
		}
	}
</script>

<style lang="scss">
	page {
		background: $page-color-base;
		padding-bottom: 100upx;
	}

	.address-section {
		padding: 30upx 0;
		background: #fff;
		position: relative;

		.order-content {
			display: flex;
			align-items: center;
		}

		.icon-shouhuodizhi {
			flex-shrink: 0;
			display: flex;
			align-items: center;
			justify-content: center;
			width: 90upx;
			color: #888;
			font-size: 44upx;
		}

		.cen {
			display: flex;
			flex-direction: column;
			flex: 1;
			font-size: 28upx;
			color: $font-color-dark;
		}

		.name {
			font-size: 34upx;
			margin-right: 24upx;
		}

		.address {
			margin-top: 16upx;
			margin-right: 20upx;
			color: $font-color-light;
		}

		.icon-you {
			font-size: 32upx;
			color: $font-color-light;
			margin-right: 30upx;
		}

		.a-bg {
			position: absolute;
			left: 0;
			bottom: 0;
			display: block;
			width: 100%;
			height: 5upx;
		}
	}

	.goods-section {
		margin-top: 16upx;
		background: #fff;
		padding-bottom: 1px;

		.g-header {
			display: flex;
			align-items: center;
			// height: 84upx;
			height: 44upx;
			padding: 0 30upx;
			position: relative;
		}

		.logo {
			display: block;
			width: 50upx;
			height: 50upx;
			border-radius: 100px;
		}

		.name {
			font-size: 30upx;
			color: $font-color-base;
			margin-left: 24upx;
		}

		.g-item {
			display: flex;
			margin: 20upx 30upx;

			image {
				flex-shrink: 0;
				display: block;
				width: 140upx;
				height: 140upx;
				border-radius: 4upx;
			}

			.right {
				flex: 1;
				padding-left: 24upx;
				overflow: hidden;
			}

			.title {
				font-size: 30upx;
				color: $font-color-dark;
			}

			.spec {
				font-size: 26upx;
				color: $font-color-light;
			}

			.price-box {
				display: flex;
				align-items: center;
				font-size: 32upx;
				color: $font-color-dark;
				padding-top: 10upx;

				.price {
					margin-bottom: 4upx;
				}
				.number{
					font-size: 26upx;
					color: $font-color-base;
					margin-left: 20upx;
				}
			}

			.step-box {
				position: relative;
			}
		}
	}
	.yt-list {
		margin-top: 16upx;
		background: #fff;
	}

	.yt-list-cell {
		display: flex;
		align-items: center;
		padding: 10upx 30upx 10upx 40upx;
		line-height: 70upx;
		position: relative;

		&.cell-hover {
			background: #fafafa;
		}

		&.b-b:after {
			left: 30upx;
		}

		.cell-icon {
			height: 32upx;
			width: 32upx;
			font-size: 22upx;
			color: #fff;
			text-align: center;
			line-height: 32upx;
			background: #f85e52;
			border-radius: 4upx;
			margin-right: 12upx;

			&.hb {
				background: #ffaa0e;
			}

			&.lpk {
				background: #3ab54a;
			}

		}

		.cell-more {
			align-self: center;
			font-size: 24upx;
			color: $font-color-light;
			margin-left: 8upx;
			margin-right: -10upx;
		}

		.cell-tit {
			flex: 1;
			font-size: 26upx;
			color: $font-color-light;
			margin-right: 10upx;
		}

		.cell-tip {
			font-size: 26upx;
			color: $font-color-dark;

			&.disabled {
				color: $font-color-light;
			}

			&.active {
				color: $base-color;
			}
			&.red{
				color: $base-color;
			}
		}

		&.desc-cell {
			.cell-tit {
				max-width: 90upx;
			}
		}

		.desc {
			flex: 1;
			font-size: $font-base;
			color: $font-color-dark;
		}
	}
	
	/* 支付列表 */
	.pay-list{
		padding-left: 40upx;
		margin-top: 16upx;
		background: #fff;
		.pay-item{
			display: flex;
			align-items: center;
			padding-right: 20upx;
			line-height: 1;
			height: 110upx;	
			position: relative;
		}
		.icon-weixinzhifu{
			width: 80upx;
			font-size: 40upx;
			color: #6BCC03;
		}
		.icon-alipay{
			width: 80upx;
			font-size: 40upx;
			color: #06B4FD;
		}
		.icon-xuanzhong2{
			display: flex;
			align-items: center;
			justify-content: center;
			width: 60upx;
			height: 60upx;
			font-size: 40upx;
			color: $base-color;
		}
		.tit{
			font-size: 32upx;
			color: $font-color-dark;
			flex: 1;
		}
	}
	
	.footer{
		position: fixed;
		left: 0;
		bottom: 0;
		z-index: 995;
		display: flex;
		align-items: center;
		width: 100%;
		height: 90upx;
		justify-content: space-between;
		font-size: 30upx;
		background-color: #fff;
		z-index: 998;
		color: $font-color-base;
		box-shadow: 0 -1px 5px rgba(0,0,0,.1);
		.price-content{
			padding-left: 30upx;
		}
		.price-tip{
			color: $base-color;
			margin-left: 8upx;
		}
		.price{
			font-size: 30upx;
			color: $base-color;
		}
		.submit{
			display:flex;
			align-items:center;
			justify-content: center;
			width: 280upx;
			height: 100%;
			color: #fff;
			font-size: 32upx;
			background-color: $base-color;
		}
	}
	
	/* 优惠券面板 */
	.mask{
		display: flex;
		align-items: flex-end;
		position: fixed;
		left: 0;
		top: var(--window-top);
		bottom: 0;
		width: 100%;
		background: rgba(0,0,0,0);
		z-index: 9995;
		transition: .3s;
		
		.mask-content{
			width: 100%;
			min-height: 30vh;
			max-height: 70vh;
			background: #f3f3f3;
			transform: translateY(100%);
			transition: .3s;
			overflow-y:scroll;
		}
		&.none{
			display: none;
		}
		&.show{
			background: rgba(0,0,0,.4);
			
			.mask-content{
				transform: translateY(0);
			}
		}
	}

	/* 优惠券列表 */
	.coupon-item{
		display: flex;
		flex-direction: column;
		margin: 20upx 24upx;
		background: #fff;
		.con{
			display: flex;
			align-items: center;
			position: relative;
			height: 120upx;
			padding: 0 30upx;
			&:after{
				position: absolute;
				left: 0;
				bottom: 0;
				content: '';
				width: 100%;
				height: 0;
				border-bottom: 1px dashed #f3f3f3;
				transform: scaleY(50%);
			}
		}
		.left{
			display: flex;
			flex-direction: column;
			justify-content: center;
			flex: 1;
			overflow: hidden;
			height: 100upx;
		}
		.title{
			font-size: 32upx;
			color: $font-color-dark;
			margin-bottom: 10upx;
		}
		.time{
			font-size: 24upx;
			color: $font-color-light;
		}
		.right{
			display: flex;
			flex-direction: column;
			justify-content: center;
			align-items: center;
			font-size: 26upx;
			color: $font-color-base;
			height: 100upx;
		}
		.price{
			font-size: 44upx;
			color: $base-color;
			&:before{
				content: '￥';
				font-size: 34upx;
			}
		}
		.tips{
			font-size: 24upx;
			color: $font-color-light;
			line-height: 60upx;
			padding-left: 30upx;
		}
		.circle{
			position: absolute;
			left: -6upx;
			bottom: -10upx;
			z-index: 10;
			width: 20upx;
			height: 20upx;
			background: #f3f3f3;
			border-radius: 100px;
			&.r{
				left: auto;
				right: -6upx;
			}
		}
	}

</style>
